Error Handling এবং Logging Behaviors

Microsoft Technologies - উইন্ডোজ কমিউনিকেশন সিস্টেম (WCF) - WCF Service Behaviors এবং Custom Behaviors Creation
206

WCF (Windows Communication Foundation) একটি শক্তিশালী প্রযুক্তি যা বিভিন্ন ধরনের অ্যাপ্লিকেশন এবং সিস্টেমের মধ্যে যোগাযোগের জন্য ব্যবহৃত হয়। তবে, বাস্তব অ্যাপ্লিকেশনগুলিতে সার্ভিস ব্যবহারের সময় বিভিন্ন ধরনের Error Handling এবং Logging প্রয়োজন। WCF এর Error Handling এবং Logging Behaviors এর মাধ্যমে, আমরা আমাদের অ্যাপ্লিকেশনের সমস্যা সনাক্তকরণ, সমাধান এবং ডিবাগিং সহজ করতে পারি।

এই টিউটোরিয়ালে আমরা দেখব কিভাবে Error Handling এবং Logging Behaviors ব্যবহার করা যায় WCF সার্ভিসে।


১. Error Handling in WCF

WCF Error Handling এর মূল উদ্দেশ্য হলো সার্ভিসে ঘটিত ত্রুটিগুলিকে সঠিকভাবে পরিচালনা করা, যাতে অ্যাপ্লিকেশনটি ভেঙে না পড়ে এবং ব্যবহারকারীকে যথাযথ তথ্য দেওয়া যায়। Error Handling দুটি স্তরে করা যায়:

  1. Application-Level Error Handling (Global Error Handling)
  2. Service-Level Error Handling (Per-Service Error Handling)

১.১ Application-Level Error Handling

Global Error Handling করতে হলে WCF এর IErrorHandler ইন্টারফেস ব্যবহার করতে হয়, যা WCF সার্ভিসের মধ্যে ঘটিত ত্রুটিগুলি হ্যান্ডেল করতে ব্যবহৃত হয়।

IErrorHandler ইন্টারফেসের মাধ্যমে Error Handling:
  1. IErrorHandler ইন্টারফেস ইমপ্লিমেন্ট করুন।
  2. HandleError মেথড ব্যবহার করে ত্রুটির বিবরণ সংগ্রহ করুন এবং ProvideFault মেথড ব্যবহার করে ফল্ট তৈরি করুন।
public class CustomErrorHandler : IErrorHandler
{
    public bool HandleError(Exception error)
    {
        // এখানে ত্রুটির লগ বা ডিবাগিং করা যেতে পারে
        Console.WriteLine("Error: " + error.Message);
        return true; // এখানে true মানে error সঠিকভাবে হ্যান্ডেল করা হয়েছে
    }

    public void ProvideFault(Exception error, MessageVersion version, ref Message fault)
    {
        // এখানে কাস্টম ত্রুটি বার্তা তৈরি করা যেতে পারে
        FaultException faultException = new FaultException("An error occurred during processing.");
        fault = Message.CreateMessage(version, faultException, "http://tempuri.org");
    }
}
  1. ServiceBehavior ব্যবহার করে ErrorHandler ইনজেক্ট করুন:
[ServiceBehavior(IncludeExceptionDetailInFaults = true)]
public class MyService : IMyService
{
    // সার্ভিসের কোড
}
  1. ErrorHandler চালু করার জন্য ServiceHost ক্লাসে হ্যান্ডলার যোগ করুন:
public class MyServiceHost : ServiceHost
{
    protected override void OnOpening()
    {
        base.OnOpening();
        this.Description.Behaviors.Add(new CustomErrorHandler());
    }
}

১.২ Service-Level Error Handling

সার্ভিস-লেভেল এও ত্রুটি হ্যান্ডলিং করা যায়। উদাহরণস্বরূপ, কিছু নির্দিষ্ট সার্ভিসের মধ্যে try-catch ব্লক ব্যবহার করা যেতে পারে, যেখানে exception হ্যান্ডেল করা হবে:

public string GetData(int value)
{
    try
    {
        // ডেটা প্রক্রিয়া করা
        return "Data for value " + value;
    }
    catch (Exception ex)
    {
        // ত্রুটি হ্যান্ডলিং
        throw new FaultException("An error occurred while processing the request.");
    }
}

২. Logging Behaviors in WCF

Logging হল সিস্টেমের কার্যকলাপ ট্র্যাক করা এবং ত্রুটি বা সমস্যা চিন্হিত করা। WCF তে লোগিং করতে সাধারণত IEndpointBehavior বা IServiceBehavior ব্যবহার করা হয়। এটি WCF সার্ভিসে বিভিন্ন ধরনের Request/Response, Faults, এবং Exceptions ট্র্যাক করতে সাহায্য করে।

২.১ Basic Logging Behaviors

WCF সার্ভিসে Message Logging এর জন্য WCF এর বিল্ট-ইন Diagnostics এবং Tracing সিস্টেম ব্যবহার করা যায়। Message Logging এবং Fault Logging সেটআপ করার জন্য System.Diagnostics এর মাধ্যমে কনফিগারেশন করা যেতে পারে।

web.config ফাইলে Logging Enable করা:
<system.diagnostics>
  <sources>
    <source name="System.ServiceModel" switchValue="Information, ActivityTracing" />
    <source name="System.ServiceModel.MessageLogging" switchValue="Information, ActivityTracing">
      <listeners>
        <add name="traceListener" type="System.Diagnostics.XmlWriterTraceListener" initializeData="C:\log\trace.log" />
      </listeners>
    </source>
  </sources>

  <trace autoflush="true"/>
</system.diagnostics>

<system.serviceModel>
  <diagnostics>
    <messageLogging enabled="true" maxSize="102400" maxMessages="20" logMessagesAtTransportLevel="false"/>
  </diagnostics>
</system.serviceModel>
  • enabled="true": এটি Message Logging সক্ষম করবে।
  • maxSize: লগ ফাইলের সর্বোচ্চ আকার নির্ধারণ করে।
  • logMessagesAtTransportLevel="false": এটি মেসেজের ট্রান্সপোর্ট স্তরের ডেটা লগ করা থেকে বিরত রাখবে।

২.২ Custom Logging Behavior

আপনি যদি custom logging চান, তাহলে IServiceBehavior বা IEndpointBehavior ব্যবহার করে custom logging logic প্রয়োগ করতে পারেন। এর মাধ্যমে আপনি সার্ভিসের প্রতিটি মেসেজ লগ করতে পারেন।

Custom Logging Behavior উদাহরণ:
public class CustomLoggingBehavior : IServiceBehavior
{
    public void AddBindingParameters(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase, BindingParameterCollection bindingParameters)
    {
        // কোন অতিরিক্ত বাইনডিং প্যারামিটার যুক্ত করতে চাইলে এটি ব্যবহার করা হয়
    }

    public void ApplyDispatchBehavior(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
    {
        foreach (var endpoint in serviceDescription.Endpoints)
        {
            // এখানে লোগিং অ্যাপ্লিকেশন যুক্ত করা হতে পারে
            endpoint.Dispatcher.MessageInspector = new CustomMessageInspector();
        }
    }

    public void Validate(ServiceDescription serviceDescription, ServiceHostBase serviceHostBase)
    {
        // সার্ভিস কনফিগারেশন যাচাই করা
    }
}
CustomMessageInspector উদাহরণ:
public class CustomMessageInspector : IDispatchMessageInspector
{
    public object AfterReceiveRequest(ref Message request, IClientChannel channel, InstanceContext instanceContext)
    {
        // Incoming Request Logging
        Console.WriteLine("Received request: " + request.ToString());
        return null;
    }

    public void BeforeSendReply(ref Message reply, object correlationState)
    {
        // Outgoing Response Logging
        Console.WriteLine("Sending reply: " + reply.ToString());
    }
}

২.৩ Logging Exception

try
{
    // কিছু কাজ করা
}
catch (Exception ex)
{
    // ত্রুটি লগ করা
    File.AppendAllText("errorlog.txt", DateTime.Now + " - " + ex.Message + Environment.NewLine);
    throw new FaultException("An error occurred.");
}

সারাংশ

  • Error Handling: WCF তে ত্রুটি হ্যান্ডলিং IErrorHandler ইন্টারফেসের মাধ্যমে অথবা সাধারণ try-catch ব্লকের মাধ্যমে করা যেতে পারে। এটি সার্ভিসের মধ্যে সঠিক ত্রুটি বার্তা এবং ফল্ট ফিরিয়ে দিয়ে ক্লায়েন্টকে সহায়তা করে।
  • Logging: WCF তে লগিং করতে System.Diagnostics বা IServiceBehavior এর মাধ্যমে কাস্টম লোগিং প্রক্রিয়া ব্যবহার করা যায়। লগিং সার্ভিসের কার্যকলাপ ট্র্যাক করতে এবং সমস্যা শনাক্ত করতে সাহায্য করে।
  • Message Logging: WCF এর বিল্ট-ইন ডায়াগনস্টিকস সিস্টেম ব্যবহার করে সার্ভিসের request/response এবং faults লগ করা যেতে পারে।

এই পদ্ধতিগুলো ব্যবহার করে আপনি WCF অ্যাপ্লিকেশনের মধ্যে Error Handling এবং Logging কার্যক্রমকে আরও দক্ষ এবং কার্যকরীভাবে পরিচালনা করতে পারবেন।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...